Realisation is a subtask of Natural language generation, which involves creating an actual text in a human language (English, French, etc) from a syntactic representation. There are a number of software packages available for realisation, most of which have been developed by academic research groups in NLG.
Contents |
For example, the following Java code causes the simplenlg system[2] [1] to print out the text The women do not smoke.:
NPPhraseSpec subject = nlgFactory.createNounPhrase("the", "woman"); subject.setPlural(true); SPhraseSpec sentence = nlgFactory.createClause(subject, "smoke"); sentence.setFeature(Feature.NEGATED, true); System.out.println(realiser.realiseSentence(sentence));
In this example, the computer program has specified the linguistic constituents of the sentence (verb, subject), and also linguistic features (plural subject, negated), and from this information the realiser has constructed the actual sentence.
Realisation involves three kinds of processing:
Syntactic realisation: Using grammatical knowledge to choose inflections, add function words and also to decide the order of components. For example, in English the subject usually precedes the verb, and the negated form of smoke is do not smoke.
Morphological realisation: Computing inflected forms, for example the plural form of woman is women (not womans).
Orthographic realisation: Dealing with casing, punctuation, and formatting. For example capitalising The because it is the first word of the sentence.
The above examples are very basic, most realisers are capable of considerably more complex processing.
A number of realisers have been developed over the past 20 years. These systems differ in terms of complexity and sophistication of their processing, robustness in dealing with unusual cases, and whether they are accessed programmatically via an API (like simplenlg) or whether they take a textual representation of a syntactic structure as their input. There are also major differences in pragmatic factors such as documentation, support, licensing terms, speed and memory usage, etc.
It is not possible to describe all realisers here, but a few of the more popular ones are